## **CPEG 422/622 Spring 2020**

## Homework 2

Demo due February 26<sup>th</sup> in class, code due February 26<sup>th</sup> through Canvas. Put your name in the comment part of the code you submitted!

1. Change the 4-bit carry-ripple adder VHDL code to implement a 4-bit adder/subtractor in the way described in lecture slides. Submit your VHDL code through Canvas.

## Grading policy:

Adder/subtractor entity has A[3:0], B[3:0], M, and S[3:0], Overflow is optional -15

No syntax error – 15

Adder function is correct – 20

Note that adder implementation can be either carry-ripple or CLA

2. Implement a 4-bit **subtractor** on the Zybo Z7-10 board. Use four LEDs (3 downto 0) for the 4-bit output. The 4-bit input A comes from four switches (3 downto 0), and the 4-bit input B comes from four buttons (3 downto 0). Submit your VHDL code and corresponding constraint file through Canvas, and bring your board to class for demo.

## Grading policy:

Subtractor entity has A[3:0], B[3:0], and S[3:0], Overflow is optional – 10

No syntax error -10

Subtractor function is correct – 10

Constraint file correctly maps A to switches, B to buttons, and S to LEDs. Mapping of overflow is optional -20